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reconfigurable sequential processor includes a 
(lata bank for storing data to be processed; a prog- 
rarnmable logic block address generator for address- 
ing data in the data bank; a programmable logic 
block arithmetic unit responsive to the data bank for 
processing the data addressed by the programmable 
logic block address generator; an address generator 
hardware configuration file having a plurality of con- 
figuration files for configuring the programmable log- 
ic block address generator in one of a plurality of 
. addressingi configurations in response to an address 
bperattoriai code; an arithmetic hardware configura- 
tion file having a plurality of configuration files for 
corifiguring the programmable logic block arithmetic 
unit in one of a plurality of processing configurations 
;in response to an arithmetic operational code; and 
means for delivering a series of operational codes to 
each configuration file for enabling thtf "program- 
mable logic block address generator and the prog- 
ramrhable logic block arithmetic unit to be config- . 
ured to perfonm sequehtially a corresponding series 
of arithmetic logic operations on the data in the data 
;'-bank:. 
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' FIELD OF INVENTION . 

This invention relates to a reconfigurable se- 
quential processor, and more particularly to such a 
processor which is reconfigurable over time to im- 
plement a series of address generators and 
arithmetic logic units for performing a correspond- 
ing sequence of operations on datcu 



BACKGROUND OF INVENTION ra 

, Conventional data processing systems such as 
image data processors require extensive hardware 
to perform a series of arithmetic logic operations 
on the data. For example, image data requires the 76 
operations of image acquisition, spatial filtering, 
temporal filtering, histogram equalization, image 
display, to name just a few. Each such operation 
requirias a separate hardware implementation in 
separate boards or separate gate arrays. Such im- 20 
plementations are expensive and are relatively in- 
efficient in tfie sense that while all the necessary 
hardware is always present it is being utilized only 
a small part of the time during the period when its 
particular operation in the series is called for. The 25 
hardware actually invoh/es two corriponents: an ad- 
dress generator for selecting tiie pixel addresses in 
the sequence called for by the operation, and an 
arithmetic logic unit, which actually perfonms the 
operation on the sequenced data. 30 

The escalation of hardware required is even 
greater in pipeline systems, which feature fixed 
image data banks. A pipeline system is one in 
which a number of image processing operations 
are being perfonmed on a number of different 35 
frarnes of pixels as the franies are shifted through 
the pipeline or a series of processors. Jn one vari- 
ety of piipeline systenn where the image data is 
fixed and does not move tiirough tiie pipeline, each 
frame, must be serviced by a sequence of address 4o 
generators and associated arithmetic logic units; 
that requires two large muftiplex^r switches with , 
hfia^ive s capability to ponnect the right ; • 

pair of address generators and arithmetic logic 
units to each frame in the proper sequence. 45 

SUMMARY OF INVENTION 



tial operations on the same data 

It is a further object of this invention to provide 
such a reconfigurable sequential processor which 
provides the simultaneous processing available in 
pipeline systems with stationary data banks yet 
eliminates the need for massive multiplexer switch- 
ing capability. 

It is a furtiier object of this invention to provide 
such a reconfigurable sequential processor in 
which the processing algorithm can be changed 
easily and quickly without hardware replacement. 

The invention results from the realization that a 
truly effective and economical data processor can 
be achieved by using an address generator and an 
arithmetic unit which can be easily reconfigured 
under software control to emulate a number of 
different address sequences and arithmetic oper- 
ations, respectively, using the same programmable 
logic blocks. 

This invention features a reconfigurable se- 
quential processor including a data bank for storing 
data to be processed and a programmable logic 
block address generator for addressing data in a 
data bank. A programmable, logic block arithmetic 
unit responds to the data bank for processing the 
data addressed by the programmable logic block 
address generator. An address generator hardware 
configuration file has a plurality of configuration 
files for configuring the programmable logic block 
address generator in one of a jplurality of address 
configurations in response to ah address oper- 
ational code. An arithmetic hardwaire configuration 
file has a plurality of configuration files for configur- 
ing tiie programmable logic block arithmetic unit in 
one of a plurality of processing configurations in 
response to an aritiimetic operational code. There 
are mearfs for delivering a series of operational 
codes to each configuration file for enabling the 
programmable logic block address generator and 
the programmable logic block aritiimetic unit to be 
configured to perfonm sequentially a conresponding 
series of arithmetic logic operations on the data, in 
the data. barik.--*- '^ v. ' ■ '"^ 

In a prefenred ennbbdiment thei programmable > 
logic blocks are programmable gate arrays. The 
nneans for delivering bperafipnal codes may include 
an operational code register for storing the oper- 
ational code in the next configuration for each of ; 
the logic blocks and decoder rriieans responsive to 
tiie next operational code for selecting from the 
hardware configuration files the file corresponding 
to ttiat operational code. IT^ addi^ess generator 
may include a piurality of reconfigurabfe address 
sets and the auithnietic unit rhay include a plurality 
of reconfigurable arithnrietic circuit. The data bank, 
may include a plurality of sets of data and me 
reconfigurable sequential processor niay further in- 
clude a plurality of buses for interconnecting each 



It is therefore an object of this inventipn to 
provide a reconfigurable sequential processor.* . 50 

It is a further object of this invention to provide 
:suqh a reconfigurable sequential proces^r whose r ' 
reconfiguration is controlled by software. 

; rt is a further object of this invention to provide ^ -V 
such:,a reconfigurable sequential processor vvhich 55 
uses the same gate arrays reconfigurable in time to : 
implement specific generators and aritiimetic logic- 
units; respectively, in a number of different sequeh- 
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of the address sets and arithmetic units for the 
con^esponding one of the data sets. 

DISCLOSURE OF PREFERRED EMBODIMENT 

■ ; 5 

Other objects, features and advantages will oc- 
cur to those skilled in the art from the following 
description of a preferred embodiment and the 
accompanying dravyings, in which: 

Fig. 1 is a block diagram of a computer contain- to 
ing the reconfigurable sequential processor ac- 
cording to this invention; 

Rg. 2 is a more detailed block diagram of the 
reconfigurable sequential processor of Rg. 1- 
according to this Invention; ts 
Fig. 3 is a flow chart showing the routine which 
effects the reconfiguration of the processor 
shown in Rg. 2; 

Rg. 4 is a list of the various hardware configura- 
tion files and ttie respective operational codes 20 
that can be configured in the processor accord- 
ing to this invention; 

Rg. 5 is a diagram of the file structure for the 

address generator cohfiguration files in Rg. 4; 

Rg: 6 is a more detailed block diagram of the 25 

address generator of Rg. 2; 

Rg: 7 is a diagram similar to that in Rg. 5 of the 

file structure for the arithmetic unit of Rg. 2; 

Rg. 8 is a more detailed block djagram of the 

antiemetic unit of Rg. 2; 30 

Rg. 9 is a block diagram of ia prior art video 

image processing pipeline system; and 

Rg. 10 is a bk:)ck diagram of a video iniage 

processing, pipeline system constructed in ac^ 

cordance with the reconfigurable sequential pro- 35 

cessor of this invention. ^ 

^^"l^^re is shown in Rg. 1 a computer system 1 0 
including a reconfigurable sequential processor 12 
according to this invention. The computer may be 
an IBM PC or any other computer havirig a key- 40 
board 14, CPU 16, display 18, and a hard disk 
storage 2Q or any other suitable permanent stor- 
age. The reconfigurable sequential processor : 12 
and CPU 16 typically form plug-in boards on a 
common t)ackplane in a computer. 45 

Reconfigurable sequential processor 12. Rg. 2, 
includes address generator 22 which selects a se- 
quence of addresses from image data bank 24 that 
are.to t)e delivered to arithmetic unit 26 one at a 
time for processing and then returned to image so . 
data bank 24, The particular operation being per- 
formed may be an image acquisition, spatial filter- ' 
ing. histogram, or image display. In each case 
address generator 22, which is implemented by a 
programmable logic block such as a programmable. 55 
gate an-ay, is configured by a file selected from tiie 
hardware configuration; file circuit 28; In like man- 
ner, aritiimetic unit 26, which is also imjDiemented 
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by a programmable logic block such as a program- 
mable gate anray, is configured according to a file 
selected from hardware configuration files 30. Each 
of the configuration files 28 and 30 are loaded 
initially wHh a plurality of files such as ft-om hard 
disk 20 on lines 32 and 34. Subsequentiy. when an 
operational code identifying a particular process 
arrives at the instruction operationsU code register 
36 on line 38 from tiie CPU 16. decoder 39 is 
enabled to order one or both of the hardware 
configuration files to introduce the desired file into 
the respective units, address generator 22 and 
arithmetic unit 26. 

Although only one address bus 40 and one 
data bus 42 are shown in Rg. 2, this is not a 
necessary limitation of tfiie invention. For example, 
a plurality of address buses 40a and a pluraOty of 
data buses 42a (shown in phantom) may be used 
when address generator 22 includes a plurality of 
addres^ sets; image data bank 24 includes a plural- 
ity of data sets and arithmetic unit 26 includes a 
plurality of arithmetic circuits. In that case each 
address set in address generator 22 acts as an 
independent address generator and produces a 
specific sequence of addresses to the correspond- 
ing data set in image data bank 24. The data from 
memory locations specified by that sequence of 
addresses is processed by a corresponding 
arithmetic circuit in arithmetic unit 26. Each of 
these combinations of address set, data set and 
arithmetic circuits are interconnected by one of the 
plurality of buses shown, so that simultaneous 
pipeline-like processing can be accbriiplished, In 
addition, after the pipeline cycle of processing is 
completed the personalities or identities of the ad- 
dress sets can be reshuffled, as can the personal- 
ities or identities of the arithmetic circuits In 
arithmetic unit 26, so that a new cycle of image 
processing can be applied to tiie data sets in the 
Image data bank 24, which has not been reshuffled, 
all of this tieing done without requirement for any 
complex bus multiplejdng; . 

All of the cohfiguration files necessary for a 
particuiar processing effort may be preliminarily 
stored in address genetrator hardware configuration 
files 28 and arithmetic unit hardware configuration 
files 30. firom, for example, hard disk 20 over lines 
32 and 34, respectively. Or, each iridividijal file 
may be supplied firom hard disk 20 over lines 32 
and 34 tp their respective files 28 and 30 individ- 
ually as they are needed, in eitiier case, computer 
10 reads from the command file, step 50. the next 
propessing technique that , is to be executed: for 
exiarnple, imagej acquisition, spatial filtering, histo- 
gram operation, or the like. In consequencia, it 
identifies the operational code of the specific con- 
figuration required for that processing effort and 
places it, step 52. in instruction operational code 
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register 36. Rg: 2. Following this, decoder 39, Rg. 
2. functions to drive both configuration files 28 and 
30. In step 54. Rg. 3, decoder 39 asks, "Is recon- 
figuration required of the address, generator files?" 
If the answer is yes,- it reconfigures the address 
generator file In step 56 and then executes in step 
58; If the response is no. because, for example, the 
same configuration Is required again, the system 
moves directly to execute in step 58. Simulta- 
' neously. decoder 39 in step 60 is asking the ques- 
tion. "Is reconfiguration required with respect to the 
arithnnetic unit hardware configuration files 30?" If 
the answer is yes, that file is reconfigured in step 
32 and the system moves to execute in step 58. If 
the response is negative, the system moves di- 
rectly to the execution step 58. Note however that 
execution in step 58 will not take place unless a 
decision has been made in both step 54 and step 
60 indicating that the necessary reconfiguration, if 
any, has been effected in both files. After etxecution 
is complete, the system recycles to look for the 
next bpersrtional code in step 52, which is stored in 
the instruction operational code register 36 in re- 
sponse to the next command read in step 50 from 
the computer 10. 

A typical list 70 of available processes for 
whiph the systenri may be reconfigured and the 
associated operational codes aire shown in Rg. 4* 
where the table includes sixteen different file 
names identified under the RIe Name column 72 
having conresponding operational codes tabulated 
in the Operational code column 74. Each of the 
files has a field available of 16 kbytes and there are 
sixteen different files in all, from image acquisition 
to image display: The hardware configuration files 
could be RAM based or PROM based. In this case, 
wher? there are sfocteen files of sixteen kbytes 
each, the storage necessarily has a capacity of 256 
kbytes. \f the block is RAM based it can be re- 
toaded with new files periodically. This feature 
makes possible the use of a library of functions 
- limited oni^ storage, >: 

■ " v - v', e,g^..tti^^ . 

Each of the address generator files listed in 
Fig. 4 has a general format 80 as indicated in Rg. 

'I--.: ;y:- begihofng with a header length count block 82 
arid foilowed by data frames 1-7. Of course the 
size of the field and the number of blocks depend 
upon the particular application and no limitation is 
meant. 

; Each data frame 1^7 in Rg. 5 contains 
1 tipiris to configure the particular component cbh- 
tained in the recorifigurable address generator 22. 
Data frame 1 relates to the data source/destination 
control block. Pata frame 2 relates to the boundary 
conditions detector/initiator block Data frame 3 re- 
lates, to the memory array pointer block, data frame 
4 to the adders, block,, data frame 5 to the address 



generator parameter block, data frame 6 to the 
bank offset generator block, and data frame 7 to 
the memory timing control block. 

All of these blocks are shown jn Rg. 6 as 
5 constituting a general implementation of the ad- 
dress generator 22. Address generator 22 includes 
a data source destination control 90. Data source 
cohfrol 90. Rg. 6, sets the speed of the address 
generation and synchronizes it with the occurrence 
10 of the corresponding data. Boundary condition de- 
tector initiator 92 detects the beginning and tiie 
end or the boundaries of an image or a frame of 
data* .it distinguishes the lines from one another 
and the group of fines creating a frame or image 
IS from the next frame or image. If there is a tx>und- 
ary condition detected by circuit 92, then jump 
generator 94 directs memory array pointer 96 to 
jump over the generated address to the new jump 
address. If a condition has been indicated by 
20 boundary condition detector initiator 92, a suitable 
line jump or frame jump increment is introduced. 
Otherwise the generated address is passed from 
the memory array pointer 96 to the adders 98. The 
magnitude of the jump introduced by jump gener- 
25 ator 94 is detenmined by the address generator 
parameter block 100. Adders 98 may actually in- 
clude four separate adders 102. 104. 106 and 108 
as an example, which are offset an amount deter- 
mined by bank offset generator 110, which pemntts 
30 the generation of four addresses from a single 
address pointer. This is done in certain types of 
filtering where a selected pixel must be convolved 
with a number of adjacent pixels. Memory timing 
control 1 12 indicates whettier a write or read opera- 
35 tion is cunrentiy being performed and iderrtifies the 
correct tinne for the mernory to strobe the ad- 
dresses output from address 102, 104, 106 and 
1 08. If the system is configured as an image ac- 
quisition address generator then^ the jump ger^r- 
40 ator is eliminated since the data is likely stored 
sequentially and no jump is necessary. If the ad- 
dress generator is configured, as a sp<^^ 
the dka jsource destination may be 

eliminated, since tiie data is taken from the mem- 
45 ory writteri baick to it without any outside source or 
destination. When address generator 22 is perfonm- 
ing a histogram operation tiie data source destina- 
tion control 90 is again eliminated since the data is 
supplied from and returned to tiie memory directfy, 
50 and the additional adders 104, 106 and 108 are 
also eliminated since in a histograrh. operation there 
\ is no need to provide multiple;^ 
frorn Wjsjngle address. When address generator 22 
. is configured for image display operation, all of the 
55 adders as weir as the bank offset generator may be 
eliminated since a simple image display does not 
require multiple address outputs. 

The . file fpnrnat 120. . Rg. .7, for the arithmetic 
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unit 26 is the same as the file format 80 for the 
address, generator 22. Fig. 5. Each data frame 
contains Instructions to configure the particular 
component contained in the reconfigurable 
arithmetic unit 26. -There Is a header length count 
122 followed by seven data frames. Data frame 1 
contains the configuration instructions for the FIFO 
and data in blocks. Data frame 2 relates to the 
adder/subtractor block. Data frame 3 to the multi- 
plier block, data frame 4 to the lookup table, data 
frame 5 to the sorter/detector, data frame 6 to. the 
ALU control, and data frame. 7 to the parameter 
block. All of these blocks are shown in Rg. 7 as 
constituting a general implementation of the 
arithmetic unit 26. 

A generalized block diagram of arithmetic unit 
26, Rg. 8, includes a data-in FIFO 130 which 
receives external data and delivers it to a first 
multiplexer 132, which also receives internal data 
from intemal data FIFO 134. A second multiplexer 
136 also receives as an input the intemal data from 
FIFO 134 as well as the output from parameter 
block 138. Parameter block 138 typically provides 
an identification of the particular table to be se- 
lected in lookup table 140, or the multiplying factor 
to be used in multiplier 142. or the offset to be , 
used in adder/subtractor 144, as well as threshold ' 
levels for tiie detector/sorter circuit 146 and histo- 
gram operations: ALU contror allows synchroniza- 
tion of data in FIFO 130, data-out FIFO 150. and 
the various muttiplexers 132. 136 and 152, as well 
as intemal data FIFO 134. Multiplexer 152 controls 
the input to intemal data FIFO 134 from its own 
feedback loop, from memory data in. and from the 
detector/sorter 146 feedback loop. 

In the image acquisition mode, arithmetic unit 
26 requires only data-out FIFO 150. lookup feble 
140, and data-in FIFO 130, along witii parameter 
block 138 and ALU control 148. The remainder of 
the circuits, all of the multiplexers, the intemal data 
FIFO, adder/subtiractor, and multiplier are neces- 
sary because an image acquisition system assem- 
bly taking in data; from the external FIFO , 130, may . 
transfomn it using lookup table 140 and provide it at 
Vie output through data-out FIFO 1 50. 

When arithmetic unit 26 is operating as a spa- 
tial filter, detector sorter 146 may be eliminated 
since, tile detecting , and sorting required for histo- 
grams is not used in the spatial filtering in tiiis 
application. 

^^ / W arithmetic unit 26 is operating in the 
histogram mode, detector/sorter 146 is again nec- 
essary, but adder/subtractor 144. multiplier 142 
muftiplexers isa and .136, and data-in FIFO 130. 
are eliminated since tiiey are unnecessary in histo- 
grarn operations. In histogram operations the data 
is compared and binned, and multiplying, adding 
and subtracting are typically not required functions. 



When arithmetic, unit 26 is operating In the image 
display mode it requires only intemal data FIFO 
134. data output FFO 150. lookup table 140. pa- 
rameter block 138, and ALU control 148. since data 
5 . is only coming in from the memory, is to^sformed 
by lookup table data 140 and is put out again to 
the display. The foregoing discussion of the gen- 
eralized and more specific implementation of the 
address generator and arithmetic units to perform 
10 certain types of processing such as image display, 
histogram, spatial filtering and image acquisition, 
are for purposes of illustration only: the invention 
may be used for many other processing modes not 
limited to these, and may use processing tech- 
15 niques which differ from the specific implementa- 
tions shown here as they form no part of the 
instant invention. Address generator 22 and 
arithmetic unit 26. Figs 2. 6 and 8, may be imple- 
mented witii field programmable gate arrays avail- 
20 able from XILINX Inc. 

Previously, with respect to Rg. 2. it was ex- 
plained that the address generator 22 and 
arithmetic unit 26 may be interconnected witti the 
image data bank 24 by a number of buses in each 
25 case. If that is done, a pipeline approach, of si- 
multaneous processing of different sets of data 
according to different modes, e.g.. image display, 
spatial filtering, histograms, may be accomplished. 
In addition, after each such cycle oif processing the 
30 location of ttie different address sets and arithmetic 
circuits within the address generator and arithmetic 
unit, respectively, may be reshuffled to repeat tiie 
processing cycle witii different data sets. 

In one prior art approach. Rg. 9. a partial 
36 attempt at this has been made. In a prior art video 
image processing pipeline system 200. Rg. 9. 
there are a plurality of fixed address gerierators 
202. each of which communicates with a separate 
bus 204 via multiplier, mux, 206. and a second bus 
40 208 to Individual frames or sets of data in memory 
or data bank 210. Similariy, an arithmetic unit 212 
including a plurality of fixed arithmetic circuits, is 
interconnected by a plurality of bus^ 214 th^^ 
mux 216 and a second plurality of buses 218 to 
45 memory 210. 

: In operation, each of tfie address drcutts in 
address generator 202 is permanently connected 
through a specific bus to the mux 2G6i Mux 206 
theri determines which of the incoming buses is to 
50 be connected tb which of tiie outgoing buses so 
tiiat each of the frames in memory 210 can be 
processed according to the address sequence In a 
* different one of the address sets as the operation Is 
recycled. Similarly, each of the arithmetic circuits 
55 212 is connecte.d to a specific dedicated bus 214, 
which mux 216 selectively interconriects with buses 
218 in order to pemnit different frames in rhemory 
210 to be processed by different arithmetic circuits 
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during each cycle of operation. Although this sys- 
tem does accomplish a pipeRne type of simulta- 
neous processing without having to actually move 
the frames of data, it suffers from the shortcoming 
that it requires two complex multiplexers 206 and 
216, each of which contains massive switching 
capability. 

According to this Invention, a much simpler 
and more hardware-efficient system can be con- 
structed by providing an address generator 22a 
which includes a plurality of address sets each of 
which is connected by a different bus 40a to one of 
the data sets in image data bank 24a. Similarly, 
arithmetic unit 26a includes a plurality of arithmetic 
.circuits which are interconnected with the data sets 
in image data bank 24a by means of a plurality of . 
buses 42a. However, in accordance with this inven- 
. tion, no multiplexers are needed. For after a cycle 
of .operation is completed, i.e.. each frame has 
received the sequence of addresses fromi its asso- 
ciated address set in address generator 22a over 
the con*esponding dedicated bus 40a and the pixel 
data has been processed in accordance with that 
address sequence by the associated arithmetic cir- 
cuit in aritiimetic unit 26a. the entire address gen- 
erator can be reshuffled so tiiat each cf the ad- 
. „ dress sets changes place and a sjmilar reconfigura- 
tion can be accomplished with respect to the 
arithmetic circuits in arithmetic unit 26a. Thus ttie 
pipeline or parallel processing has been accom- 
plished witiiout moving the data sets and yet with- 
out requiring the complex and massive multiplexing 
capability of the prior art 

Although specific features of the invention are 
shown in some drawings and not others, this is for 
; convenience only as each feature may be conn- 
bined with any or all of the other features in accor- 
dance with the invention. 

Other ehnbodiments will occur to those skilled 
in the art and are within the foltowing clams: 

1. A reconfigurable sequential processor compris- 
/ . ■ , ing: •. . .. • . 

: ■ ; / a data bank for storing data to be ^^ p 
',; -cessed; 

a programmable logic block address gen-? 
eraitor for addressing data in said data back; 

a programmable logic block arithmetic 
■ unit, responsive to said data bank, for process-/ 
: ; ing the data addressed by said , programmable 

logic block address generator; 
;. ; ah address, generator : hardvyare corifigura- 
V .tion file haying a plurality of configuration files 
for configuring said programmable logic bk)ck 
address generator in one of a plurality of ad- 
: ' ' dressing configurations in response to an ad- 



dress operational code; 

an arithmetic hardware configuration file 
having a plurality of configuration files for con- 
figuring said programmable logic block 

5 arithmetic unit in one of a plurality of process- 

ing configurations in response to an arithmetic 
operational code; and 

means for delivering a series of operation- 
al codes to each configuration file for enabling 

10 said programmable logic block address gener- 

ator and sakj programmable logic block unit to 
be configured to perform sequentially a cor- 
responding series of arithmetic logic oper- 
ations on said data in said data bank. 

16 

2, The reconfigurable sequential processor of 
claim 1 in which said programmable logic 
blocks are programmable gate arrays. 

20 3. The reconfigurable sequential processor of 
clainni 1 in which said means for delivering said 
operational codes includes an operational code 
register for storing the operational code of the 
next configuration for each of said logic blocks. 

25 and decoder means, responsive to said next 

operational code for selecting from said hard- 
ware configuration files the file conresponding 
to said operational code. 

30 4. The reconfigurable sequemial processor of 
claim 1 in which said means for delivering said 
. address generator includes a plureility of recon- 
figurable address sets. 

36 5. The reconfigurable sequential processor of 
claim 4 in which said arithmetic unit incltides a 
plurality of reconfigurable arithmetic circuits. 

6. The reconfigurable sequential processor of 
40 claim 5 in which said data bank includes a 

plurality of sets of data 

7. the reconfigurable sequential processor of 
claim 6 further including a plurality of buses for 

45 interconnecting each of said address sjets and 

. arithmetic units with a corresponding onei of . 
said data sets. 

50 
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@ A reconfigurable: sequential processor includes a 
data bank for storing data to be processed; a prog- 
ranrimable logic bkx:k address generator for address- 
ing^ data in the data bank; a programmable logic 
block arithmetic unit responsive to the data bank for 
processing the data addressed by the programmable 
logic block address generator; an address generiator 
hardware configuration file having a plurality of con- 
figuration files for configuring the programmable log- 
ic block address generator in one of a plurality of 
addressing configurations in response to an address 
operational code; an arithmetic hardware configura- 
tion file having a plurality of configuration files for 
configuring the programmable logic block arithmetic 
unit In one of a plurality of processing configurations 
in response to an arithmetic operational code; and 
means for delivering a series of operational codes to 
each configuration file for enabling the program-' 
mable logic block address generator and the prog- 
rammable logic block arithmetic unit to be config- 
ured to perform sequentially a corresponding series 
of arithmetic logic operations on the data in the data 
bank. 
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